Method and system for optimized FIFO full condition control

ABSTRACT

Method and system for generating an optimized full signal in a FIFO device. In one embodiment of the present invention, the optimized full signal control circuit checks the storage capacity of the FIFO memory by aggregating the number of occupied word entries and the number of occupied pipelines.

BACKGROUND OF INVENTION

[0001] 1. Field of Invention

[0002] The present invention relates generally to computer systems. More particularly, the present invention relates to an optimized control circuit for generating a full signal in a First In First Out (FIFO) device.

[0003] 2. Related Art

[0004] Data transfer in computer systems is typically conducted between a sending element and a receiving element according to a handshake protocol. In computer systems, data is often transmitted from the sending element at a higher rate than it can be consumed at the receiving element. In order to facilitate data communication between the sending element and the receiving element, high-speed buffers such as First In First Out (FIFO) memory devices are used.

[0005] A FIFO device typically comprises a plurality of serially arranged storage cells (or memory locations) which are sequentially written into and read from. A write address pointer holds the write binary address of the storage cell into which data will be written during the next write operation, and a read address pointer holds the read binary address of the storage cell from which data will be read during the next read operation.

[0006]FIG. 1 illustrates a conventional FIFO device 100. FIFO device 100 comprises: a FIFO memory element 101, a write address circuit 103, a write multiplexer 105, a read address circuit 107, a read multiplexer 109, an up-down counter 111, and a FULL/EMPTY signal generator 113. Moreover, memory element 101 may be a RAM (Random Access Memory) in which reading and writing of data may be performed simultaneously and comprises a capacity of N words. While a read permission signal (RE) is asserted, data (RDATA) is read from an address designated by a read address (RADR) on a word-by-word basis at a clock timing of a clock signal CLK. Similarly, while a write permission signal (WE) is asserted, data (WDATA) is written into an address designated by a write address (WADR) on a word-by-word basis at a clock timing of the clock signal CLK.

[0007] The read address circuit 107 receives the clock signal CLK and the read permission signal (RE). While the read permission signal (RE) is asserted, the read address circuit 107 increments the read address (RADR) by one at a clock timing of the clock signal CLK.

[0008] The write address circuit 103 receives the clock signal CLK and the write permission (WE). While the write permission signal (WE) is asserted, the write address circuit 103 increments the write address (WADR) by one at a clock timing of the write clock signal CLK.

[0009] When up-down counter 111 receives an asserted write enable (WE) signal, the counter enables a count-up signal (U) which allows a count-up operation. Moreover, when up-down counter 111 receives an asserted read enable (RE) signal, the counter enables a count-down signal (D) which allows a count-down operation. While one of the count-up enable signal (U) or the count-down enable signal (D) is asserted, the up-down counter 111 performs a count operation at a clock timing of the clock CLK. A count value count of the up-down counter 111 is output to FULL/EMPTY signal generator 113.

[0010] Signal generator 113 receives the count value count from up-down counter 111. If the received count value count is 0, the signal generator 113 outputs an empty signal E, indicating that memory 101 has no data to be read.

[0011] In one embodiment of a conventional FIFO device, pipelines are not used in conjunction with the FIFO device. In this embodiment, if the received count value count equals N (the number of words available in memory 101), signal generator 113 outputs a full signal F, indicating that memory 101 has no more storage capacity available.

[0012] In an alternate embodiment of a conventional FIFO device, pipelines are used in conjunction with the FIFO device. In this alternate embodiment, assuming M number of pipelines are used wherein each pipeline is capable of storing one data word, if the received count value count equals N (the number of words available in memory 101)-M (the maximum number of words stored in the pipelines), signal generator 113 outputs a full signal F, indicating that memory 101 has no more storage capacity available. As an illustrative example, FIFO memory 101 in FIG. 1 receives data from 5 pipelines denoted Pipeline0, Pipeline1, Pipeline2, Pipeline3, and Pipeline4. In this example, signal generator 113 generates a full signal F if count equals to N−5.

[0013] The conventional FIFO device illustrated in FIG. 1 may be used to facilitate the data rate discrepancy between the sending element and the receiving element. However, such conventional FIFO devices do not take into consideration possible idle pipelines that do not contain any data, and therefore may generate a full signal while the FIFO memory is still capable of storing additional data.

SUMMARY OF INVENTION

[0014] Accordingly, the present invention provides a method and a system for generating an optimized full signal in a FIFO device. In one embodiment of the present invention, each of one or more pipelines from which a FIFO device obtains data is checked for valid data entry. For each pipeline, a corresponding validity bit is set to zero if the pipeline contains no data and the corresponding validity bit is set to one if the pipeline contains a valid data entry. Moreover, a count value count (shown in FIG. 1) is then aggregated with the validity bits in order to generate a total sum. The sum is compared to the storage capacity of the FIFO memory, and a full signal is generated if the two values equal.

[0015] The FIFO full signal control circuit of the present invention allows more optimized use of FIFO memory storage by generating full signals according to occupied pipelines rather than counting all pipelines indiscriminatingly.

BRIEF DESCRIPTION OF DRAWINGS

[0016] The accompanying drawings that are incorporated in and form a part of this specification illustrate embodiments of the invention and together with the description, serve to explain the principles of the invention:

[0017]FIG. 1 is a prior art architectural diagram illustrating a conventional FIFO device.

[0018]FIG. 2 is an architectural diagram illustrating a FIFO device comprising an optimized full signal control circuit in accordance to one embodiment of the present invention.

[0019]FIG. 3 is a flow chart diagram illustrating functional steps of an optimized full signal control circuit in accordance to one embodiment of the present invention.

DETAILED DESCRIPTION OF EXEMPLARY EMBODIMENT (S)

[0020] The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. In the following description, specific nomenclature is set forth to provide a thorough understanding of the present invention. It will be apparent to one skilled in the art that the specific details may not be necessary to practice the present invention. Furthermore, various modifications to the embodiments will be readily apparent to those skilled in the art and the generic principles herein may be applied to other embodiments. Thus, the present invention is not intended to be limited to the embodiments shown but is to be accorded the widest scope consistent with the principles and features described herein.

[0021]FIG. 2 illustrates a FIFO device 200 according to one embodiment of the present invention. FIFO device 200 comprises: a FIFO memory element denoted 201, a write control circuit denoted 202A, a read control circuit denoted 202B, an up-down counter denoted 211, an adder denoted 215, and a comparator denoted 219. Memory element 201 may be a RAM (Random Access Memory) in which reading and writing of data may be performed simultaneously and comprises a capacity of N words.

[0022] Write control circuit 202A further comprises a write address circuit denoted 203 and a write multiplexer denoted 205. While a write permission signal (WE) is asserted, data (WDATA) is written into an address designated by a write address (WADR) on a word-by-word basis at a clock timing of a clock signal CLK.

[0023] During a write operation, write control circuit 202A receives the clock signal CLK and the write permission (WE). While the write permission signal (WE) is asserted, the write address circuit 203 increments the write address (WADR) by one at a clock timing of the clock signal CLK. Moreover, while the write permission signal (WE) and the clock signal CLK are asserted, multiplexer 205 selects input “1” in order to increment the write address (WADR) by one.

[0024] Read control circuit 202B further comprises a read address circuit denoted 207 and a read multiplexer denoted 209. While a read permission signal (RE) is asserted, data (RDATA) is read from an address designated by a read address (RADR) on a word-by-word basis at a clock timing of the write clock signal CLK.

[0025] During a read operation, read control circuit 202B receives the clock signal CLK and the read permission (RE). While the read permission signal (RE) is asserted, the read address circuit 207 increments the read address (RADR) by one at a clock timing of the clock signal CLK. Moreover, while the read permission signal (RE) and the clock signal CLK are asserted, multiplexer 209 selects input “1” in order to increment the read address (RADR) by one.

[0026] Furthermore, when up-down counter 211 receives an asserted write enable (WE) signal, the counter enables a count-up signal (U) which allows a count-up operation. When up-down counter 211 receives an asserted read enable (RE) signal, the counter enables a count-down signal (D) which allows a count-down operation. While one of the count-up enable signal (U) or the count-down enable signal (D) is asserted, the up-down counter 211 performs a count operation at a clock timing of the clock CLK. A count value count of the up-down counter 211 is then output to adder 215.

[0027] In the embodiment shown in FIG. 2, FIFO memory 201 receives data WDATA from five pipelines denoted Pipeline0, Pipeline1, Pipeline2, Pipeline3, and Pipeline4, each pipeline having a storage capacity of one data word. The pipelines Pipeline0, Pipeline1, Pipeline2, Pipeline3, and Pipeline4 further correspond to validity bits held in registers Valid0, Valid1, Valid2, Valid3, and Valid4 respectively. A validity bit is set to zero if its corresponding pipeline does not contain any data. Conversely, a validity bit is set to one if its corresponding pipeline contains a valid data entry. The pipelines Pipeline0, Pipeline1, Pipeline2, Pipeline3, and Pipeline4 are connected in series and the data stored in a first pipeline is piped to the next pipeline at each clock cycle as shown by the arrows interconnecting each pipeline to the next and ultimately to FIFO memory 201. Similarly, as the data is piped from one pipeline to the next, the validity bit corresponding to the data is piped from one validity register to the next as shown by the arrows interconnecting each validity register to the next.

[0028] Furthermore, the values of the validity bits are input to adder 215 and aggregated with output of up-down counter 211 denoted count. The adder then outputs an aggregated sum denoted 217. Comparator 219 takes as input sum 217 and N (the number of words available in FIFO memory 201), compares the two input values, and output a full signal if the two input values equal.

[0029]FIG. 3 is a flow chart illustrating the functional steps of an optimized full signal control circuit in accordance to one embodiment of the present invention. In step 301, all pipelines that input to a FIFO memory are checked for valid data. For each pipeline, from step 303 to step 307, if a pipeline contains valid data, a corresponding validity bit is set to one. Conversely, if a pipeline does not contain data, a corresponding validity bit is set zero. Subsequently in step 309, the validity bits corresponding to the pipelines are aggregate with a count values received from an up-down counter to obtain a sum. The sum is then compared to the storage capacity of the FIFO memory in step 311 and a logical one is generated as output 221 if the sum and the value of the FIFO memory capacity equal. Conversely, a logical zero is generated as output 221 in step 311 where the sum does not equal to the value of the FIFO memory capacity.

[0030] Output 211 constitutes a full signal wherein the value of signal 211 indicates whether or not the FIFO memory is full. Output 213 constitutes an empty signal wherein the value of signal 213 indicates whether or not the count value generated by the up-down counter 211 is zero.

[0031] The foregoing descriptions of specific embodiments of the present invention have been presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed, and obviously many modifications and variations are possible in light of the above teaching. The embodiments were chosen and described in order to best explain the principles of the invention and its practical application, to thereby enable others skilled in the arts to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the Claims appended hereto and their equivalents.

[0032] For example, although five pipelines are illustrated in FIG. 1 and FIG. 2, one skilled in the art understands that a greater or fewer number of pipelines may be used in conjunction with the FIFO device according to desired design parameters. 

I claim:
 1. A method of optimally generating a full signal in a FIFO device, the method comprising: checking one or more pipelines for valid data, wherein the one or more pipelines may comprise data written to a FIFO memory; adding the number of pipelines comprising valid data to a count output of an up-down counter to produce a sum; and comparing the sum to a storage capacity value of the FIFO memory.
 2. The method of claim 1, wherein the sum equals to the storage capacity value of the FIFO memory.
 3. The method of claim 2, further comprising the step of generating a full signal signifying that the FIFO memory is full.
 4. The method of claim 1, wherein the sum does not equal to the storage capacity of the FIFO memory.
 5. The method of claim 4, further comprising the step of generating a signal signifying that the FIFO memory is not full.
 6. The method of claim 1, further comprising the step of enabling a count-up signal in the up-down counter that allows a count-up operation while a write enable signal is asserted in the FIFO device.
 7. The method of claim 6, further comprising the step of performing a count operation at a clock timing of a clock while the count-up signal is enabled.
 8. The method of claim 1, further comprising the step of enabling a count-down signal in the up-down counter that allows a count-down operation while a read enable signal is asserted in the FIFO device.
 9. The method of claim 8, further comprising the step of performing a count operation at a clock timing of a clock while the count-up signal is enabled.
 10. The method of claim 1, further comprising the step of generating the count output from the up-down counter.
 11. A method of optimally generating a full signal in a FIFO device, the method comprising: checking one or more pipelines for valid data, wherein the one or more pipelines may comprise data written to a FIFO memory; inputting one or more validity bits into an adder, wherein each of the one or more validity bits corresponds to each of the one or more pipelines respectively; aggregating the validity bits to a count output of an up-down counter to produce a sum; and comparing the sum to a storage capacity value of the FIFO memory.
 12. The method of claim 11, wherein a validity bit of the one or more validity bits comprises a zero if the validity bit corresponds to a pipeline having no valid data.
 13. The method of claim 12, wherein a validity bit of the one or more validity bits comprises an one if the validity bit corresponds to a pipeline having valid data.
 14. The method of claim 11, wherein the sum equals to the storage capacity value of the FIFO memory.
 15. The method of claim 14, further comprising the step of generating a full signal signifying that the FIFO memory is full.
 16. The method of claim 11, further comprising the step of enabling a count-up signal in the up-down counter that allows a count-up operation while a write enable signal is asserted in the FIFO device.
 17. The method of claim 16, further comprising the step of performing a count operation at a clock timing of a clock while the count-up signal is enabled.
 18. The method of claim 11, further comprising the step of enabling a count-down signal in the up-down counter that allows a count-down operation while a read enable signal is asserted in the FIFO device.
 19. The method of claim 18, further comprising the step of performing a count operation at a clock timing of a clock while the count-down signal is enabled.
 20. The method of claim 11, further comprising the step of generating the count output from the up-down counter.
 21. An optimized full signal condition control circuit, comprising: a FIFO memory element having a limited storage capacity; one or more pipelines coupled in series to the FIFO memory element, wherein each pipeline may comprise data to be written to the FIFO memory element; an adder coupled to the one or more pipelines for receiving a valid value from each of the one or more pipelines, wherein each pipeline comprising data outputs an one as its valid value to the adder and each pipeline having no data outputs a zero as its valid value to the adder; and an up-down counter coupled to the adder for sending a count value to the adder as an input.
 22. The control circuit of claim 21, wherein the adder aggregates the valid value of each of the one or more pipelines and the count value of the up-down counter, and outputs the sum.
 23. The control circuit of claim 22, further comprising a comparator coupled to the adder, wherein the comparator compares the output of the adder to the storage capacity value of the FIFO memory element.
 24. The control circuit of claim 23, wherein the comparator having a first input coupled to the output of the adder and a second input having the FIFO memory storage capacity value.
 25. The control circuit of claim 21, further comprising a write enable signal coupled to a count-up input of the up-down counter.
 26. The control circuit of claim 21, further comprising a read enable signal coupled to a count-down input of the up-down counter.
 27. An optimized full signal condition control circuit, comprising: a FIFO memory element having a limited storage capacity; one or more pipelines coupled in series to the FIFO memory element, wherein each pipeline may comprise data to be written to the FIFO memory element; one or more validity registers coupled to the one or more pipelines, wherein each of the one or more validity registers is coupled to each of the one or more pipelines respectively; an adder coupled to the one or more validity registers for receiving a valid value from each of the one or more validity registers; and an up-down counter coupled to the adder for sending a count value to the adder as an input.
 28. The control circuit of claim 27, wherein the one or more validity registers are coupled in series.
 29. The control circuit of claim 28, wherein a validity register of the one or more validity registers outputs a zero as its valid value if the validity register is coupled to a pipeline having no valid data.
 30. The method of claim 29, wherein a validity register of the one or more validity registers comprises outputs an one as its valid value if the validity register is coupled to a pipeline having valid data.
 31. The control circuit of claim 30, wherein the adder aggregates the valid values and the count value of the up-down counter and outputs a sum.
 32. The control circuit of claim 31, further comprising a comparator coupled to the adder, wherein the comparator compares the output of the adder to the storage capacity value of the FIFO memory element.
 33. The control circuit of claim 32, wherein the comparator having a first input coupled to the output of the adder and a second input having the FIFO memory storage capacity value.
 34. The control circuit of claim 27, further comprising a write enable signal coupled to a count-up input of the up-down counter.
 35. The control circuit of claim 27, further comprising a read enable signal coupled to a count-down input of the up-down counter. 